5. Installatie van Python en MicroPython 


Python is een programmeertaal die begin jaren 90 ontworpen en ontwikkeld werd 
door Guido van Rossum van het Centrum voor Wiskunde en Informatica in 
Amsterdam. De ontwikkeling van de taal wordt nu geleid door de Python Software 
Foundation. Python is vrije software. Python heeft zijn naam te danken aan het 
favoriete televisieprogramma van Guido van Rossum, Monty Python's Flying Circus. 


Python is op korte tijd heel populair geworden. Veel hogescholen en universiteiten 
onderwijzen Python als eerste computertaal. Waarom? 


e Python is eenvoudig aan te leren. Python programma’s vallen op door 
compactheid en helderheid. Bovendien zijn er geen puntkomma’s en 
accolades nodig, talen zoals C staan er bol van. 

e Python is een heel krachtige taal, er zijn heel veel softwarebibliotheken 
beschikbaar. 

e Je kunt met Python interactief werken. Je geeft een opdracht en je krijgt 
direct een resultaat. Dat is ideaal om snel iets uit te proberen. 

e Voor talen zoals C, C++, … bestaan er compilers die de broncode vertalen 
naar machinetaal die de computer zo kan uitvoeren. Een Python 
programma wordt niet gecompileerd, de interpreter zal de instructies van 
het programma één voor één uitlezen en direct uitvoeren. Het voordeel is 
dat we een programma heel snel kunnen wijzigen. Dat heeft ook nadelen: 
een Python programma is langzamer dan een gecompileerd programma. 
Bovendien moeten moet de interpreter op het doelsystem geïnstalleerd 
zijn. We hebben dus krachtigere controllers nodig maar die zijn 
tegenwoordig goed verkrijgbaar en veel kosten ze ook niet meer. 


e Python is object georiënteerd, zie verder in dit boek. 


MicroPython is een implementatie van Python en is geoptimaliseerd om op 
microcontrollers te werken. Microcontrollers hebben veel minder geheugen dan 
Pc's. Net zoals bij Python wordt de code niet gecompileerd, maar tijdens het 
uitvoeren geïnterpreteerd. Je vind MicroPython op www.micropython.org . 


MicroPython is board-specifiek en controller-specifiek. Een versie voor controller A 
is niet compatibel met die voor controller B. Voor elke controller bestaan er 
verschillende controller bordjes en MicroPython probeert voor de meeste bordjes 
een eigen versie van de software te ontwikkelen. Op de downloadpagina van 
MicroPython zie je een overzicht. Heb je een bordje dat niet in die lijst staat, probeer 
dan de software van een bordje met dezelfde controller, dat werkt waarschijnlijk. 
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Sommige versies zijn nog niet volledig klaar, daar ontbreken nog stukken van. Van 
sommige versies bestaat er alleen een voorlopige versie. 


De systeemsoftware voor MicroPython op de downloadpagina is een bestand met 
extensie .uf2 of .bin of nog iets anders. Gebruik het .uf2-bestand, tenzij je hieronder 
de .bin nodig hebt. 


Hoe werkt MicroPython op een RP2040? De bootloader in de ROM van de RP 2040 
doet enkele controles bij het opstarten. Als knop BOOTSEL is ingedrukt bij het 
opstarten of als er geen software in het FLASH geheugen zit, dan gedraagt de RP2040 
zich als een schijfstation van de PC. We kunnen dan software overbrengen naar het 
FLASH geheugen. In het andere geval wordt de software in de FLASH uitgevoerd. Als 
de bootloader een interpreter vindt en Python programma main.py, dan start 
main.py op. Staat er geen main.py in de FLASH, dan start de interpreter op in 
interactieve modus. We hebben dus software nodig op de PC om programma’s in te 
voeren en software om programma’s over te zeten naar de controller. Voor die taken 
gebruiken we programma Thonny. 


Thonny 

Thonny is gemaakt aan de universiteit van Tartu in Estland. Je vindt het programma 
op https://thonny.org . Bovenaan die webpagina zie je een link naar de downloads, 
o.a. voor Windows. Download de Windows installer en voer die uit. Je krijgt 
waarschijnlijk enkele waarschuwingen, o.a. van de virusscanner. Negeer die. 


Installatie van MicroPython door Thonny 

Download eerst de meest recente versie van Micropython voor jouw systeem. Die 
vind je op de downloadpagina van micropython.org. Op die pagina staat veel 
informatie, kies eerst de MCU (de controller) van jouw systeem. Heb je een RP2040, 
dan vind je een heleboel bordjes met een RP2040. De versie voor de Raspberry Pi 
Pico werkt met alle RP2040 bordjes. Heb je een ESP8266 of een ESP32, dan staat 
jouw systeem waarschijnlijk niet in de lijst. Kies dan ESP32/ESP8266 Espressif. Let op, 
er bestaan Releases en Nightly Builds. Een Nightly Build is een voorlopige, niet 
stabiele versie. Een Release is een stabiele versie. Kies de Release met het hoogste 
versienummer. Na downloaden staat de software in folder Downloads van de PC. 


Je installeert MicroPython door de interpreter te installeren in het Flash-geheugen 
van de controller. Dat kan met Thonny: start Thonny op en sluit het bordje aan op 
een USB-poort van de PC. Ga naar menu Tools - Options — Select Interpreter en kies 
MicroPython voor jouw systeem. Klik dan onderaan op Install or Update firmware om 
de interpreter te installeren in de controller. 
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Th Thonny options x 


General Interpreter Editor Theme &Font Run & Debug Terminal Shell Assistant 


Which interpreter or device should Thonny use for running your code? 


Details 


Connect your device to the computer and select corresponding port below 
(look for your device name, "USB Serial” or “UART”). 
If you can't find it, you may need to install proper USB driver first. 


Port 
< Try to detect port automatically > { 


Install or update firmware 


Figuur 20: configuratie van Thonny 


Th ESP8266 firmware installer x 


This dialog allows installing or updating firmware on ESP8266 using the most common settings. 
If you need to set other options, then please use 'esptool' on the command line. 


Note that there are many variants of MicroPython for ESP devices. If the firmware provided 
at micropython.org/download doesn't work for your device, then there may exist better 
alternatives -- look around in your device's documentation or at MicroPython forum. 


Port Silicon Labs CP210x USB to UART Bridge (COM19) ~ Reload 
Firmware \C:/Users/dirkg/Downloads/esp8266-20210902-v1.17.bin Browse... 
Flash mode 

@ From image file (keep) O Quad 1/0 (qio) 

© Dual 1/0 (dio) © Dual Output (dout) 


Ld] Erase flash before installing 


Install Cancel 


Figuur 21: installatie van de software 


Stel de juiste Poort in. De automatische detectie van de poort werkt niet altijd even 
vlot. Klik op het keuzeknopje naast Port zonder aangesloten controller en ga na 
welke poortnummers beschikbaar zijn. Sluit dan de controller aan, open de options 
en ga terug kijken bij Port. De extra poort in dat scherm is de poort voor de jouw 
bordje, selecteer die. Laat de andere instellingen ongewijzigd en druk op Install. Even 
later zijn Thonny en MicroPython klaar voor gebruik. Opmerking: de standaard 
instelling van de Flash mode is from image. Dat werkt meestal. In enkele gevallen 
werkt het niet. Je kunt de image laden naar de controller, maar die werkt dan niet. 
Probeer dan de andere instellingen. Voor de ESP8266/ESP8285 kies je Dual I/O. 
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Deze installatiemethode werkt alleen als Thonny de controller 


hiervoor 


ondersteund. De ondersteunde controllers vind je bij Thonny in Menu Tools — 


Options — Interpreter. Voor een niet -ondersteunde controller gebruik je één van 


volgende methodes. 


Th Thonny options 
General Interpreter Editor Theme & Font Run & Debug Terminal Shell Assistant 


Which interpreter or device should Thonny use for running your code? 
MicroPython (ESP8266) 


The same interpreter which runs Thonny (default) 
[Alternative Python 3 interpreter or virtual environment 
Remote Python 3 (SSH) 

MicroPython (SSH) 

MicroPython (BBC micro:bit) 

MicroPython (Raspberry Pi Pico) 

MicroPython (ESP32) 
Mic hon (ES! 
MicroPython (generic) 
CircuitPython (generic) 

A special virtual environment (deprecated) 


Port or WebREPL 
USB-SERIAL CH340 (COM16) 


Install or update firmware 


Cancel 


Figuur 22: ondersteunde controllers 


Installatie van MicroPython door kopiéren 


Sommige controllers kunnen zich voordoen als een extra schijfeenheid. Een RP2040 


breng je in die toestand door hem op te starten of te resetten met ingedrukte BOOT- 
toets. Voor andere, zoals de SAMD21 moet je tweemaal de resettoets indrukken. Als 


de controller in die toestand staat, dan kan je de software er gewoon in kopiëren. 


Na een reset is MicroPython klaar voor het gebruik. 


Installatie m.b.v. Thonny 


Je kunt Micropython in sommige controllers installeren m.b.v. Thonny, zie de figuur 


hierboven. Klik op install or udate firmware. 
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TA 


General Interpreter Editor Theme & Font Run & Debug Terminal Shell Assistant 


st7789_picop 4elp 
Which interpreter or device should Thonny use for running your code? ^ 
MicroPython (ESP8266) 5 Features 
Details 


Th £58266 firmware installer 

Connecting via | 

Connect your de 

(look for your This dialog allows installing or updating firmware on ESP8265 using the most common settings. 
it you cant tina, lf you need to set other options, then please use ‘esptool' on the command line. 


Connecting via) Note that there are many variants af MictoPython for ESP devices. If the firmware provided 
It your devices at mictopython.ora/download doesn't work for your device, then there may exist better a 

Gmportwebrep alternatives … look around in your device's documentation or at MicroPython forum. pe han 
< WebREPL > bi ne 


Shell Port or WebRER ral topics 
Silicon Labs CP; Port (Silicon Labs CP210x USB to UART Bridge (COM24) “|| Reload 3 
Unable 
Firmware |C/Users/dirka/Downloads/esp8266-20230426-v1.20.0.bin Browse. 
Backend 
sas Flash mode e te 
D From image file (keep) © Quad 1/0 (qic) 
Dual 1/0 dio) © Dual Output (dou) Object inspector 
E Erase flash before installing Data Attributes 
MicroPython (generic) 
Install Cancel 


Figuur 23: installatie m.b.v. Thonny 


Kies de juiste USB-poort en blader naar het gewenste firmware-bestand. Voor een 
esp8266/esp8285 stel je de flash mode in als Dual 1/0, voor de andere kies je From 
image file. 


Installatie op een ESP-controller 

Op de website van Espressif vind je een online tool om ESP-controllers te 
programmeren. Download de MicroPython-versie voor jouw controller en start de 
tool, zie https://espressif.github.io/esptool-js 


a (ô NEER 
E RPL ED nanopi PD attinyss @ Goog ge a 
ESP Tool ° 

= 


A Serial Flasher utility for Espressif chips 


a) Bu GG @ ab 


E Andere favorieten 


Program 


6 
Baudrate: 921500 v | cammer | x 
w 
4 


Console 


oo 


& 


Figuur 24: ESP-tool 


e Sluit de controller aan en klik op Connect 


s27= 


espressif.github.io wil verbinding maken met een seriéle poort 


CP2104 USB to UART Bridge Controller (COM19) - Gekoppeld 
SPP Dev (COM4) 


Bluetooth-randapparaat (COM5) 


Verbinding maken Annuleren 


Figuur 25: ESP-tool, verbinding maken 


e Selecteer de USB-poort van de controller. (COM19 in het voorbeeld) en 
klik op verbinding maken. 


o [010 ]@18 D1. {tx ee io 15 m lif See 
€ GA ô js//espressif.github.io, m g A GG @ E (b) 
G Google BD RPI ED nanopi PT attiny8s @ Google Contacts A Afbeeldingen > | ED Andere tavorieten Q 
Sy ESP Tool á 
A Serial Flasher utility for Espressif chips = 
2 
Program o 

Connected to device: ESP32-D0WDQ6 (revision 1) 

Erase Hash 

=| z 
Flash Address File w 
0x1000 Bestand kiezen | esp32-202 . v1 19 1 bin - 
o 


Figuur 26: ESP-tool, bestand kiezen 


e Klik op kies bestand, kies de software die je gedownload hebt voor de 
controller en klik op program. Na enkele minuten is de controller klaar. 
Reset hem door even los te koppelen. 


De instructies voor andere controllers vind je op de downloadpagina’s van 
micropython.org. 


Installatie van Thonny op niet-Windows toestel 
Thonny werkt ook op Macintosh, op een Raspberry Pi 4 computer en op een Linux- 
systeem. Op thonny.org vind je meer informatie. 
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Gebruik van Thonny 

Het shell-venster is het grote vak onderaan links. Hier kan je Python commando’s 
geven. Die worden uitgevoerd door de controller. Typ een opdracht en je krijgt direct 
een resultaat. Merk op dat Python de wiskundig juiste volgorde van bewerkingen 
gebruikt. 


Th Thonny - <untitled> @ 1:1 - oF x 
File Edit View Run Tools Help 
aa © © 


<untitied> Help 


Shell 


>>> 1+2*3 Assistant 
RA 


>>> 


MicroPython (Raspberry Pi Pico) 


Figuur 27: Thonny interactief 


In het bovenste venster is het editor-venster. Hier typ je een programma in. De 
editor herkent de meest voorkomende typfouten, zoals ontbrekende haakjes en 
aanhalingstekens, en markeert die met een kleur. Typ het programma van het 
voorbeeld hieronder in. Je start het programma op met de F5-toets of met het start- 
pictogram, het groene knopje van de werkbalk. Thonny vraagt waar je het 
programma wilt bewaren. Dat kan op de PC of op de controller. Bewaar het op de 
PC. Als alles goed gaat zal het programma de LED van het bordje laten knipperen. 
Wil je de controller stand-alone gebruiken, dan moet je het programma bewaren op 
de controller met naam main.py, het start dan automatisch op bij het opstarten van 
de hardware. 
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Th Thonny - Raspberry Pi Pico: /main.py @ 4:2 = je x 
File Edit View Run Tools Help 
Sd 0 @ 


[mainpy]* Help 


from machine import Pin 
from time import sleep 
led = Pin(25, Pin.OUT) 
while True: 
led.toggle() 
sleep(@.2) Assistant 


Shell 


oie B28 
7 


MicroPython (Raspberry Pi Pico) 


Figuur 28: programma blink.py 


Een programma moet bewaard worden voor we het kunnen uitvoeren. 


Als er bij de uitvoering fouten optreden, dan geeft de interpreter een foutmelding. 
Soms is de fout eenvoudig te herstellen. Indien niet, kan je de debugger gebruiken. 
Die start je met Contr-F5. De debugger voert het programma regel per regel uit. 
Daarbij verschijnen in kleurige venstertjes de variabelenamen met hun inhoud, 
resultaten van expressies en van functieaanroepen. 
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